<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Manage Names List</title>
    <style>
        body {
            font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
            margin: 20px;
            color: #333;
            background-color: #f5f5f5;
        }
        h1 {
            color: #2c3e50;
            border-bottom: 2px solid #2c3e50;
            padding-bottom: 10px;
        }
        form {
            background: #ffffff;
            padding: 20px;
            border-radius: 8px;
            box-shadow: 0 0 10px rgba(0,0,0,0.1);
            margin-bottom: 30px;
        }
        label {
            display: block;
            font-weight: bold;
            margin-bottom: 8px;
        }
        input[type="text"], input[type="number"], input[type="date"] {
            width: 100%;
            padding: 10px;
            border: 1px solid #ddd;
            border-radius: 4px;
            box-sizing: border-box;
            margin-bottom: 12px;
        }
        button {
            background-color: #007bff;
            color: #ffffff;
            border: none;
            padding: 10px 15px;
            border-radius: 4px;
            cursor: pointer;
            font-size: 16px;
            transition: background-color 0.3s;
        }
        button:hover {
            background-color: #0056b3;
        }
        .alert {
            background-color: #d4edda;
            color: #155724;
            border: 1px solid #c3e6cb;
            padding: 15px;
            border-radius: 4px;
            margin-top: 20px;
        }
        .error {
            background-color: #f8d7da;
            color: #721c24;
            border: 1px solid #f5c6cb;
        }
    </style>
    <!-- Include jsPDF library -->
    <script src="https://cdnjs.cloudflare.com/ajax/libs/jspdf/2.5.1/jspdf.umd.min.js"></script>
</head>
<body>
    <h1>Manage Names List</h1>

    <!-- Form to specify the starting name, number of names, and date -->
    <form id="displayForm">
        <label for="startName">Starting Name:</label>
        <input type="text" id="startName" name="startName" required>
        <label for="numNames">Number of Names to Display:</label>
        <input type="number" id="numNames" name="numNames" min="1" required>
        <label for="displayDate">Date:</label>
        <input type="date" id="displayDate" name="displayDate">
        <button type="submit">Download Names List as PDF</button>
    </form>

    <!-- Form to input a name to remove -->
    <form id="removeForm">
        <label for="removeName">Name to Remove:</label>
        <input type="text" id="removeName" name="removeName" required>
        <button type="submit">Remove Name</button>
    </form>

    <!-- Notifications container -->
    <div id="notificationContainer"></div>

    <script>
        const { jsPDF } = window.jspdf; // Get jsPDF from the global window object
        const displayForm = document.getElementById('displayForm');
        const removeForm = document.getElementById('removeForm');
        const notificationContainer = document.getElementById('notificationContainer');

        // Predefined list of names
        let predefinedNames = [
            "Alice", "Bob", "Charlie", "David", "Eve",
            "Frank", "Grace", "Hannah", "Ivy", "Jack",
            "Karen", "Leo", "Mona", "Nina", "Oscar"
        ];

        // Function to generate PDF content
        function generatePDFContent(startName, count, displayDate) {
            const pdf = new jsPDF();
            pdf.setFontSize(16);
            pdf.text('Names List', 20, 20);

            if (displayDate) {
                pdf.setFontSize(12);
                pdf.text(`Date: ${displayDate}`, 20, 30);
            }

            let y = 40; // Initial vertical position for the list
            const startIndex = predefinedNames.indexOf(startName) + 1; // Start after the given name
            if (startIndex <= 0 || startIndex >= predefinedNames.length) {
                pdf.setFontSize(12);
                pdf.text('Starting name not found or no subsequent names in the list.', 20, y);
            } else {
                const endIndex = Math.min(startIndex + count, predefinedNames.length);
                for (let i = startIndex; i < endIndex; i++) {
                    pdf.setFontSize(12);
                    pdf.text(`${i - startIndex + 1}. ${predefinedNames[i]}`, 20, y);
                    y += 10; // Move to the next line
                }
            }

            return pdf;
        }

        // Function to trigger the download of the PDF
        function downloadNamesList(startName, count, displayDate) {
            const pdf = generatePDFContent(startName, count, displayDate);
            pdf.save('names_list.pdf');
        }

        // Function to remove all occurrences of a specified name
        function removeName(nameToRemove) {
            predefinedNames = predefinedNames.filter(name => name !== nameToRemove);
        }

        // Function to display notifications
        function showNotification(message, type) {
            const notification = document.createElement('div');
            notification.className = `alert ${type}`;
            notification.textContent = message;
            notificationContainer.appendChild(notification);
            setTimeout(() => notification.remove(), 5000);
        }

        // Handle display form submission
        displayForm.addEventListener('submit', function(event) {
            event.preventDefault(); // Prevent form submission
            
            const startName = document.getElementById('startName').value.trim();
            const numNames = parseInt(document.getElementById('numNames').value, 10);
            const displayDate = document.getElementById('displayDate').value;

            if (numNames <= 0) {
                showNotification('Please enter a valid number greater than 0.', 'error');
                return;
            }

            downloadNamesList(startName, numNames, displayDate); // Trigger PDF download
        });

        // Handle remove name form submission
        removeForm.addEventListener('submit', function(event) {
            event.preventDefault(); // Prevent form submission
            
            const removeNameInput = document.getElementById('removeName');
            const nameToRemove = removeNameInput.value.trim();
            
            if (nameToRemove === '') return; // Don't proceed if the input is empty
            
            removeName(nameToRemove); // Remove name from predefined list

            // Notify user of successful removal
            showNotification(`Name "${nameToRemove}" removed from the list.`, '');

            removeNameInput.value = ''; // Clear the input field
        });

    </script>
</body>
</html>
